草庐IT

带表锁定的 Mysql 事务

全部标签

ruby-on-rails - 在 Heroku 上重启后长时间运行的 delayed_job 作业保持锁定状态

当Herokuworker重新启动时(根据命令或作为部署的结果),Heroku将SIGTERM发送到worker进程。对于delayed_job,SIGTERMsignaliscaught然后工作人员在当前作业(如果有)停止后停止执行。如果工作人员需要很长时间才能完成,那么Heroku将发送SIGKILL。在delayed_job的情况下,这会在数据库中留下一个锁定的作业,不会被其他工作人员接收。我想确保作业最终完成(除非出现错误)。鉴于此,解决这个问题的最佳方法是什么?我看到两个选项。但我想获得其他输入:修改delayed_job以在收到SIGTERM时停止处理当前作业(并释放锁定)

ruby - 我如何找出为什么 gem 包将 gem 锁定在特定版本?

我正在尝试指定thriftgem的一个版本在我的gem文件中。gem'thrift',"~>0.6.0"当我尝试运行bundleinstall时,出现此错误:Youhaverequested:thrift~>0.6.0Thebundlecurrentlyhasthriftlockedat0.5.0.Tryrunning`bundleupdatethrift`如何找出导致它锁定在早期版本的原因?它是否符合我在gem文件中列出的另一个gem的要求?还是因为安装的版本是0.5.0,在gem文件中指定版本不会更新已安装的gem? 最佳答案

ruby-on-rails - gem install mysql2 v '0.3.11' 无法在 Yosemite 上运行

在ruby​​版本1.9.3(rvm)上执行mysql2版本0.3.11的捆绑安装或直接gem安装时,我收到以下错误。但是当我安装最新版本0.3.16时它可以工作。我还包含了我的gcc版本以供引用。Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./Users/ginocarlocortez/.rvm/rubies/ruby-1.9.3-p547/bin/rubyextconf.rbcheckingforrb_thread_blocking_region()...yescheckingforrb_wait_for_si

ruby-on-rails - 无法在 Windows 7 上安装 MySQL2 gem

我在安装时收到以下错误消息,如果我需要发布更多详细信息,请告诉我。我按照以下位置的说明操作:https://github.com/oneclick/rubyinstaller/wiki/Development-Kit我正在使用ruby​​1.9.2p136(2010-12-25)[i386-mingw32]。这是我得到的:E:\work_desk\trunk>geminstallmysql2-v0.2.4TemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...ERR

ruby-on-rails - MySQL2 gem 无法安装

长期以来,我一直在尝试在我的Ubuntu12.04服务器上安装Gitlab,在我运行bundleinstall之前一切顺利。它说它无法安装MySQL2,但没有给出原因或纠正措施。home/gitlab/gitlab$sudo-ugitlab-Hbundleinstall--deployment--withoutdevelopmenttestpostgresFetchinggemmetadatafromhttp://rubygems.org/.......Fetchinggemmetadatafromhttp://rubygems.org/..Usingrake(10.0.1)Using

ruby - 不使用 Rails 将 Ruby 连接到 Mysql

如何在没有Rails的情况下将Ruby连接到Mysql?我想使用Rubystandalone编写纯ruby​​代码来制作Web应用程序。没有抽象 最佳答案 看这里require"mysql"#ifneeded@db_host="localhost"@db_user="root"@db_pass="root"@db_name="your_db_name"client=Mysql::Client.new(:host=>@db_host,:username=>@db_user,:password=>@db_pass,:database=>

ruby-on-rails - 如何使用 ActiveRecord 连接设置事务隔离级别?

我需要以一种跨数据库(至少是SQLite、PostgreSQL、MySQL)可移植的方式在每个事务的基础上管理事务隔离级别。我知道我可以手动完成,就像那样:User.connection.execute('SETSESSIONTRANSACTIONISOLATIONLEVELSERIALIZABLE')...但我希望是这样的:User.isolation_level(:serializable)do#...end 最佳答案 此功能由ActiveRecord本身支持:MyRecord.transaction(isolation::re

ruby - 思维狮身人面像未知类型 'mysql';跳绳

我使用的是ts版本2.0.5、rails3.0.9和mysql20.2.11尝试使用rakets:index创建索引时,出现以下错误:ERROR:source'technical_core_0':unknowntype'mysql';skipping.我的development.sphinx.conf包含:sourcetechnical_core_0{type=mysqlsql_host=localhostsql_user=rootsql_pass=sql_db=ps_developmentsql_sock=/tmp/mysql.socksql_query_pre=SETNAMESut

ruby-on-rails - 如何在 Rails 控制台中查看 MySQL 查询

这个问题在这里已经有了答案:HowtoshowSQLqueriesrunintheRailsconsole?(8个答案)关闭8年前。有没有办法在Rails控制台中查看从ActiveRecord触发了哪些MySQL查询?

ruby-on-rails - 如何在 OS X 上使用 ruby​​ 2.3 为 mysql2 gem 解析 "incompatible library version"?

我使用的是ruby​​2.3,在gemfile中,我列出了mysql2gem。但是当我尝试运行rakedb:migrate时,我得到以下信息:/Users/me/.gem/ruby/2.3.0/gems/mysql2-0.4.2/lib/mysql2.rb:31:in`require':incompatiblelibraryversion-/Users/me/.gem/ruby/2.3.0/gems/mysql2-0.4.2/lib/mysql2/mysql2.bundle(fatal)我似乎无法绕过这个。我用Homebrew安装了Mysql5.7,尝试更新包,卸载并重新安装mysql